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(54) Print control system and method 

(57) A print control system managing a print job on 
a job basis and on a page basis. When a print job is 
interpreted, a job description file and page data for each 
page are created. The job description file contains the 
attribute of the entire job and a job element (content) 
list. An item of page data is associated with the print 
attribute of each page including image data. The job 
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control module extracts necessary image data accord- 
ing to the job element list and sends it to a printer. 
Because a plurality of print jobs share the common 
data, many job management functions, inducting print 
job combination and page addition/deletion, can be 
implemented easily. 
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Description 

BACKGROUND OF THE INVENTION 

1 . Field of the Invention 5 

This invention relates to a print control system and 
method, and more particularly to print job management. 

2. Description of the Related Art 10 

Recently, print systems have rapidly becoming pop- 
ular. A typical print system has an editing unit such as a 
workstation and a print control system such as a print 
server, both connected to a network. The print control is 
system, in turn, has one or more printers connected 
either directly or via a network. Upon receiving a print 
job from the editing unit, the print control system inter- 
prets it and sends the image data of each page to the 
printer. i * 20 

A print job is usually coded in a page description 
language (PDL). Upon receiving a print job, the print' 
control system interprets the job, generates the print 
data (image data) of each page, processes (com- 
presses, saves, and decompresses) it, and then sends 25 
it to a printer. 

However, a conventional print control system has 
managed print jobs on a job basis in most cases. This 
results in the problems described below. One problem is 
that, even when a plurality of print jobs use the same 30 
page data (that is, the same image data), they cannot 
share it This means that they execute the same 
processing and, in addition, save and store the same 
data. Thus, job management is inefficient. 

The user in a- conventional print control system 35 
finds it difficult to process print jobs on a page basis 
(e.g. , the users can neither change nor add pages). This 
requires the user to modify the job on an editing unit and 
then re-submit the modified print job to the print control 
system. : - - 40 

In addition, when the user wants to change the 
page sequence or the number of copies of a particular 
page, he must modify the print job and then re-submit it 
as described above. 

Systems which save print data for later use in re- 45 
printing are found in Japanese Patent Laid-Open Publi- 
cation No. Hei 2-213930, Japanese Patent Laid-Open 
Publication No. Hei 5-201075, Japanese Patent Laid- 
Open Publication No. Hei 6-24106, Japanese Patent 
Laid-Open Publication No. Hei 6-40092, and Japanese so 
Patent Laid-Open Publication No. Hei 7-186461. How- 
ever, these systems do not manage print jobs on a job 
basis and on a page basis, and therefore do not allow a 
plurality of print jobs to share print data. 

Also found in Japanese Patent Laid-Open Publica- ss 
tion No. Hei 6-106813 is a print control system which 
stores the print data of each page to allow the user to 
change the page sequence (or to select a desired page) 
when reprinting. However, this system does not manage 



print jobs both on a job basis and on a page basis, and 
therefore a plurality of print jobs cannot share print data. 
In this conventional system, the user cannot select a 
desired page from a plurality of print jobs for printing in 
any sequence. 

As described above, a conventional print control 
system manages print jobs only on a job basis in most 
cases; a print control system featuring page-basis oper- 
ation provides only limited functions. As print systems 
have become more and more popular these days, there 
has been a long felt need for a system which satisfies 
sophisticated and diversified user requirements. 

SUMMARY OF THE INVENTION 

It is an object of this invention to provide a print con- 
trol system which manages print jobs on a job basis as 
well as on a page basis and thus gives the user a variety 
of functions. 

It is another object of this invention to provide a 
print control system which allows the user to share print 
data among a plurality of print jobs to enhance data 
processing and data storage efficiency. 

ft is still another object of this invention to provide a 
print control system which gives the user many func- 
tions including print job concurrent binding, print job 
hierarchical binding, page addition, page replacement, 
and page deletion. 

To achieve the above objects, the print control sys- 
tem according to this invention comprises: 

a job description file storage module containing job 
description files each containing a job elements list 
for each print job; * 

a page data storage module containing page data 
associated with a page image for each page; and 
a job control module extracting and sending to a 
printer a page image, required for printing, accord- 
ing to a job element list in the job description file. 

In the above configuration, a print job is managed 
by a job description file (JDF) and page data (PD) pro- 
vided for each page. That is, the print job is managed on 
a job basis and on a page basis. A job element list con- 
tained in the job description file contains one or more 
job elements (contents). This job element list associates 
the job description file with page data required for print- 
ing. * 

This new job management method allows a plurality 
of print jobs to share common page data, ft also pro- 
vides many functions not attainable in a conventional 
print control system. Those functions include page 
basis replacement, addition, deletion, and job combina : 
tion. When the contents of a job are changed, 
unchanged data is available for re-use, eliminating the 
need for the host system (job output system) to output 
the entire job again. 

In addition, the print job management method 
according to this invention allows the user to re-print 
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data, to output data to an external unit on a job basis 
and on a job description file basis, and to read data from 
an external unit 

Preferably, the system according to this invention 
includes a job interpretation module which reads s 
entered print jobs in order to create job description files 
and page data. . This job - interpretation module,, com- , 
posed of PDL interpretation module, etc., de-com- 
presses print jobs; that is, it acts as an interpreter (de- 
composer). A job. description file is created automati- 10 
cally from, the interpretation result, and page data for 
each page is also created automatically. The job inter- 
pretation module may be designed so that it functions 
as the job description file creation module or page data 
creation module. is 

Preferably, both page data and job description files 
are defined as job elements (contents). This means that 
job description files may be structured hierarchically by , 
allowing one job description file to reference another. 
This hierarchical structure enables the job control mod- 20 
ule to examine job element lists, one at a time, until all 
the page data required for job execution is collected. 
The ability to define a job description file as a job ele- 
ment gives the user means to describe, a print job, in 
which one volume of a book is printed, as a set erf print 25 
jobs each corresponding to a chapter, . 

BRIEF DESCRIPTION OF THE DRAWINGS , 

Fig. 1 is a conceptual diagram showing the basic 30 
principle of this invention. 

Fig. 2 is a diagram showing job interpretation and 
ID assignment.-", ; > ;.. .» - . , 

Fig. 3 is a diagram showing the basic configuration 
of a job description file and how a job is<executed. . 35 
Fig. 4 is a diagram showing the contents pf a job 
description file. . . 
Fig. 5 is a diagram showing, an example of a job 
description file. . . .. 

Fig. 6 is a diagram showing an example of a job 40 
description f ile. 

Fig. 7 is a diagram showing the contents. of a JDF , 
print instruction file. - ... •> 0 
Ftg. 8 is a diagram showing an example of a JDF. 
print instruction file: - 
Fig. 9 is a diagram showing the contents of a JDF 
revision instruction file. - 

Fig. 10 is a diagram showing an example of a JDF 
revision instruction file. 

Fig. 1 1 is a diagram showing an example of a JDF 
revision instruction file. ^ 

Fig. 12 is a Wockdiagram showing the embodiment 
of a print control system according to this invention.. 
Fig. 13 is a cfiagram showing an example of a con- 
tents management table. 

Fig. 14 is a diagram showing , the relationship 
among the contents described in the contents man- 
agement table. 

Fig. 15 is a flowchart showing the basic routines of 



a system according to this invention. 

Fig. 16 is a flowchart showing the print routine. 

Fig. 17 is a flowchart showing the saved job print 

routine. 

Fig. 18 is a flowchart showing the JDF edit routine. 

Fig. 19 is a flowchart showing the JDF edit routine. 

Rg.,20 is a flowchart showing the JDF edit routine. 

Fig. 21 is a diagram showing how attributes are 

changed during JDF editing. 

Rg. 22 is a diagram showing the state before JDF 

editing. 

Rg. 23 is a diagram showing how pages are printed 
in any desired sequence. 

Rg. 24 is a diagram showing how a plurality of cop- 
ies are printed. 

Rg. 25 is a diagram showing an example of a print 
operation in which a plurality^ copies are printed in 
any desired.sequence. . . 
Rg. 26 is a diagram showing the. first example of 
variable page printing. 

Rg. 27 is a diagram showing the second example of 
variable page printing. < > * ■■ 

Rg. 28 is a conceptual diagram showing the/third 
example of variable page printing. « r , 

Rg. 29 is a diagram showing the execution result of 
the third example of variable page printing. - 
Rg. 30 is a diagram showing the fourth example of 
variable page printing. • - < ., 

Rg.-31 is a flowchart showing :the Job combination 
routine. v 

Rg. 32 is a diagram showing an example of job 
combination.: 

Rg. 33 is a flowchart showing the contents deletion 
routine. 

Rg. .34. ; is a diagram showing an example of con- 
tents deletion. _ , !V . v 
Rg.-35 is a^flqwchart showing.the archive routine; 
Fig. w 36 is , a diagramjshpwing the state before 
archiving. v , ^ . ' 

Rg. 37 is a diagram showing archiving on a job 
basis;.. VJ . . 

Rg. 38 is a diagram showing how all the jobs are 
archived. i} > * 

Rg. 39 is a diagram showing the relationship 
between^ local system and an archive destination. 
Rg, 40 is a diagram showing archive information. 
Rg. ,41. is a flowchart showing the restore routine. 
Rg. 42 : is a flowchart showing the restore routine. 
Rg. ; 43 is a flowchart showing the restore routine. . 
Rg. 44 ( is a diagram showing the state before resto- 
ration. -1 ■ . . • 

Rg. 45 is a diagram showing the restore operation 
on a job basis. .*.,.. 

Rg. 46 is a diagram showing the state before resto- 
ration.. 

Rg. 47 is a diagram showing the restore operation 
on a job description file basis. 
Rg. 48 is a diagram showing the contents saved in 
internal storage. . 
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Fig. 49 is a diagram showing the print attribute of 
each item of page data shown in Fig. 49. 
Fig. 50 is a diagram showing the result produced by 
printing data with the priority on the page data print 
attribute. s 
Fig. 51 is a diagram showing the result produced by 
printing data with the priority on the job description 
file print attribute. 

Fig. 52 is a diagram showing blank page insertion 
and page number assignment. 10 
Fig. 53 is a diagram showing the page data creation 
and color correction of each color. 
Fig. 54 is a diagram showing a job description file 
and its execution result. 

Fig. 55 is a diagram showing the job description file is 
of job A and its execution result 
Fig. 56 is a diagram showing the job description f fle 
of job B and its execution result 
Fig. 57 is a diagram showing the job description file 
of job C and its execution result 20 
Fig. 58 is a diagram showing the result of job com- 
bination in the condition maintenance mode. 
Fig. 59 is a diagram showing the result of job com- 
bination in the partial condition usage mode. 
Fig. 60 is a diagram showing the result of job com- 25 
bination in the condition clear mode. 



DESCRIPTION OF PREFERRED EMBODIMENTS * 



L Principle \ 30 

Fig. 1 shows the concept of the print job control sys- 
tem according to this invention. 

The print job 10 is sent from the host system where 
software application programs creating print jobs are 35. 
running. For example, this print job 10 is described in 
the page description language (PDL). When the print ; 
control system shown in Fig. 1 receives the print job 1 0, 
it performs job interpretation on the print job 10' and ; 
divides it into one job description file (JDF) 14andaplu- 40 
ralrty items of page data (PD) 16. one for each page. 
The job description f ile'1 4 has a J DF I D and a unique I D; 
while each item of page data 16 has a page ID and a 
unique ID. 1 • \ ■ 

As will be described later, the job description file 1 4- "45 
and the page data 16 are managed as job* elements ' 
(hereinafter called contents)/ JDF IDs and page IDs 
described above are contents IDs. A content IDisa ' 
local identifier known only within the print control sys- 
tem, while a unique ID is an ID' (universal ID) known so 
both inside and outside the print control system. These 
IDs will be described later. 

As shown in Fig. 1 , the internal storage 12 contains 
the job description file 14 for each print job as well as a 
plurality items of page data 16. Each item of page data ss 
16 stored in the internal storage 12 has its own unique 
data. Basically, no duplicate data is stored. In other 
words, a plurality of print jobs can share the common 
page data 16. 



As will be described later, the job description ffle 14 
contains a job elements (contents) list and the print 
attributes such as a print sequence and the number of 
copies. These print attributes are associated with the 
whole print job. On the other hand, the page data 16 is 
associated with the print attribute of each page, the print 
attribute being composed. of image data and the print 
condition of each page and so on. 

When the print control system featuring both job- 
basis and page-basis print job management receives a 
print request for a particular print job, the job control 
module 20 finds the job description file 14 of the print 
job, references the job element list, and identifies one or 
more job elements required for the execution of the print 
job. More specifically, the job control module 20 finds 
the page data 16 required for the execution of the print 
job. When the page data 16 is found, the image data of 
each page is found and sent to the printer. At this time, 
the job control module 20 controls printing according to 
the print attribute contained in the job description file 14 
and the page data 1 6. 

The print control system featuring this management 
function can receive only a job description file from an 
external unit for printing or modify an internally-stored 
job description file with the use of the JDF editing unit 
22 to create a new job description file 14. Alternatively, 
it can send or receive a job description file 14 or page 
data 1 6 to or from the network 24 or the external storage 
26. 

Fig. 2 shows an example of print job interpretation 
and ID assignment. Fig.' 2 (A) shows the print job 10. 
Conceptually, this print job 10 is composed of the 
attribute information 30 and the page data 32 of each 
page. Upon receiving the print job 10 like this, the print 
control system interprets the job and assigns IDs as 
described above. Also, as shown in Fig. 2 (B), the sys- 
tem creates the job description file 1 4 and the page data 
16-1, 16-2, and 16-3. At this time, the job description file 
14 and page data 16-1, 16-2, and 16-3 each have con- 
tents IDs and unique IDs assigned. Fig. 2 (C) shows an 
example. 

The contents ID assigned to the job description file 
14 (JDF ID) is a local ID. In the example in Fig. 2, the ID 
number 10 is assigned to the. job description file 14. 
Similarly, the page IDs are assigned to page data 16-1, 
16-2, and 16-3. That is, the ID numbers 1 . 2, and 3 are 
assigned: Unique IDs are also assigned to the job 
description file 14 and to each page data 16-1, 16-2, 
and 16-3. This will be detailed later. 

In this embodiment, a unique ID is composed of the 
following three components: creation date, host ID iden- 
tifying the print control system, and contents ID unique 
within the print control system. 

For example, assume that the job description file 1 4 
is created at 10:00:00 on May 5th, 1995. that the host ID 
of the print control system is 12345ab6, and that the 
contents ID is 10. Then, the unique ID 
9503051 000001 2345ab600010 is assigned to the job 
description file 14. Similarly, unique IDs are assigned to 
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the page data 16-1, 46-2, and 1 6-3. . 

A unique ID is assigned to each content Qdb 
description file, page data) as described above. This ID, 
which is unique within the system, helps eliminate dupli- 
cate data, as will be described later. Note that a con- s 
tents ID is included in a unique ID in order to prevent two 
or more unique IDs from being created, for example, 
when a plurality of contents are created at the same .< 
time (within one second) or when a plurality of jobs are 
interpreted concurrently. ■ 10 

Fig. 3 shows an example of job description files and 
an example of a print execution result. As shown in Fig. • 
3 (A), the print job is composed of two job description 
files, JDF ID 10 and JDF ID 11, and five pages of page 
data, page 1 to page 5. , is 

Fig 3 (B) shows an example of a simple job descrip- 
tion file. This figure shows the two fields of the job 
description file: CorrtentsSelect and ContentslDs. The 
ContentsSelect field contains a print method. More spe- 
cifically, it contains the print sequence and the number 20 
of copies. The ContentslDs field, which functions as a . 
job element list; contains the contents IDs of the con- 
tents (that is, job elements). The sequence number of 
each contents ID within the ContentslDs field is an in- . 
file number (significant only in each file). For example, in 25 
JDF ID 10 shown in Fig. 3 (B), the in4ile number 1 is, 
assigned to the contents ID1 , the in-file number 2 to the 
contents ID2, and the in-file number 3 to the contents 
ID11. 

These in-file numbers appear in the ContentsSelect . 30 
field to show the print method. That is,* the numbers . 
within the inner brackets,, [ ], in the ContentsSelect field . 
are in-file numbers indicating the print sequence, and 
the number immediately preceding the inner-brackets, [ . 
], indicates the number of copies. For example; the,Con- 1 : 35 ■ 
tentsSelect field of JDF ID 10 in Fig. 3 specifies that; . 
pages be printed in the sequence of in-file numbers 1 , 2, 
and 3 (i.e., in the sequence of contents^ ID1, ID2, and 
ID11), one copy for each page. * 

The ContentsSelect field -of JDF ID 11 has the , t«? 
same information. However, it should be noted that the 
ContentsSelect field of JDF ID 10 contains JDF ID 1 1 
which corresponds to another J DR That is, the fields are 
hierarchically structured (nested). . 

The job description file JDF ID 10 of this print job, as 
when executed, produces the print result shown in Fig. 
3 (C). That is, pages 1 and 2 are printed according to 
the ContentsSelect field of JDF ID 10. Then; JDF ID 11 
is executed and pages 3 to 5 are printed. 

Thus, according to this embodiment, a simply-, so 
coded job description file in conjunction with a definition 
of hierarchically-structured job description files enables 
the user to carry out a variety of printing operations, as . 
will be descrfoed later. * 

Preferably, a job description file should be a text file, ss . 
A text file allows the user to manage the file with the use . 
of contents IDs and unique IDs, to save it on a portable 
medium such as a floppy disk or a magneto optical disk, 
and to read it into the system from such a medium. In 



addition, a text file allows the user to send or receive a 
job description file over a network. 

IL Explanation of Job Description File • - . 

Fig. 3 shows only the major items of a job descrip- 
tion f fle. An actual job description file can have some 
other attribute items included. Fig. 4 shows an example. 

As shown in Fig. 4, the header, 34, of a job descrip- 
tion file contains the comment %%JobDescriptionFile. 
This comment statement is used to determine the type 
of input data, as described below. The Title field, 36, 
contains a document name. The ContentsSelect field, 
38, contains print method information (print sequence 
and number of copies) described using in-file numbers 
as shown in Fig. 3 (B). As explained above, in-file num- 
bers are def ined.as the sequence numbers of the items 
described in the ContentslDs field, 50. 

The MediaSelect field, 40, contains a paper size, 
and the MediaPrecedence field, 42, contains informa- 
tion determining which paper size to use (page size in 
the job description file or paper size in the page t data)* 
This will be described later. The Color field, 44, speci- 
fies a color print option: black-and-white, color, or a 
color specification in the page data. The Plex field, 46,, 
specifies the printing mode: double side printing or sin-, 
gle side printing. The Copy field, 48, specifies the. 
number of copies to be produced in the system. The 
ContentslDs field, 50, contains a contents list, the ele- 
ment of the list being assigned in-file numbers sequen- 
tially from left to right beginning with 1 . The HoldTiming 
field, 52, specifies. whether to hold a print job at one of; 
two points in time: before job interpretation and before 
printing (after job interpretation).- Job interpretation is 
sometimes called Raster, Image Processing (RIP). The 
JobSave field, 54, specifies whether to save, after print- 
ing, a print job in the state before job interpretation. The 
RipFileSave field, 56, specifies whether to save, after 
printing, a print job in the state after job interpretation. 

. The attributes shown in Fig. 4 are, specified based 
on the analysis result of a print job. For those attributes 
not specified for the print. job, information associated 
with the print job or the default values are set. Note that 
the configuration of a job description file may be modi- 
fied according to the print control system functions. 

Fig. 5 shows the first example of a job description 
file, and Fig. 6 shows the second example. The Con- 
tentslDs. field in Fig. 5 contains contents IDs, while.the 
ContentslDs field in Fig. 6 contains unique IDs. As 
described above, each content is managed with a con- 
tent ID within the print control system, but with a unique 
ID outside the print control system. . - . ■ ■ 

IE. Explanation of Other Files 

Fig., 7 shows the. contents of a JDF print instruction 
fae (JPF). When the job description file 14 is in the inter- 
nal storage 12 as shown in Fig. 1 , this ffle is used to re- 
print data by specifying the unique ID of the job descrip-- 
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tion file. As shown in Fig. 7, the file begins with the com- 
ment %%JDFPrint, 58, followed by the unique ID, 60, of 
the job to be printed. 

Fig. 8 shows an example of the JDF print instruction 
file with the unique ID of 96031 42020202345ab600001 s 
of a job description file. This JDF print instruction ffle 
allows the user to use and re-print already-saved data 
without having to submit a new print job. The operation 
will be described later. 

Fig. 9 shows the contents of the JDF revision 10 
instruction file (JRF). This JDF revision instruction file 
allows the user to re-print data while modifying the job 
description file. As shown in Fig. 9, the JDF revision 
instruction file begins with the comment %%JDF Revise, 
62, followed by the unique ID of the JDF to be revised, is 
Revisions are specified in the attribute fields to be 
revised. In this example, relation changes are specified 
in the ReplaceSet field 64. Each relation change is 
specified in the form [contents in-file number, $ attached 
page number]. 20 

Contents in-file numbers are sequence numbers of 
the contents described in the ContentslDs field, 68. The 
OriginaUDFDelete field, 66, contains information as to 
whether to delete the original JDF. The ContentslDs 
field, 68, contains a contents list which contains the 25 
numbers of pages attached to the JRF if any. The field 
70 contains the comment %%JDFReviseEnd, indicating 
the end of this file. Page data to be used as replacement 
follows this comment. 

To change other items, it is necessary to describe 30 
them as in the job description file shown in Fig. 4. The 
ReplaceSet field, 64, is used to replace pages, but not 
to add pages. The ContentslDs contains unique IDs for 
contents and, when adding pages, specifies pages in 
the form ^page-number". In Figs. 10 and' 11 show 35 
examples of the JDF revision instruction file. Revision - 
and re-printing using the JDF revision instruction file will ' 
be detailed later. 

IV. System Configuration ■ <o 

Fig. 12 shows the overall configuration of a pre- 
ferred embodiment of the print control system according 
to this invention. 

The print control system 72 is implemented; for 45 
example,- by a computer having the print control* pro- 1 
gram in storage (ROM or hard disk). The program will 
be described below in detail. 

The system control module 74 controls the print 
control system 72. The input data acceptance module -so 
76 accepts input data and sends it to the input data con- 
tent determination module 78. The input data content 
determination module 78 determines the type of input 
data; that is, it checks if the input is a print job, job 
description file (JDF), JDF print instruction file (JPF), or 55 
JDF revision instruction file (JRF). To determine the 
type of input data, the module references the comment 
at the start of input data. If the comment is %%JobDe- 
scriptionFile, the module determines that the input is a 



job description file; if the comment is %%JDFPrint, the 
module determines that the input is a JDF print instruc- 
tion file; if the comment is %%JDFRevise. the module 
determines that the input is a JDF revision instruction 
ffle. If no such identifier, or a comment, is found, the 
module determines that the input is a print job. Input 
data processing based on the determination result will 
be detailed later with reference to the flowcharts, 

When the input data is a print job, the job interpre- 
tation module 82 expands the job; that is, it interprets 
the job. The job interpretation module 82 extracts the 
print attribute from the print job and generates the 
image data of each page: The compression module 84 
compresses the image data and sends it the data mem- 
ory 80. The data memory 80 stores not only such image 
data but also print jobs as necessary. 

The print attribute extracted through job analysis is 
sent to the JDF creation module 86, which creates a job 
description file described above. The created job 
description file is stored in the JDF storage module 90. 
At this time, the ID assignment module 88 assigns a 
contents' ID and a unique ID to the job description file. 

The print attribute' extracted through job analysis 
includes the print attribute that constitutes the page 
data. The ID assignment module 88 assigns contents 
IDs and unique IDs to the page data as it does for the 
job description file. 

The contents management table 92, a table for 
managing created job description files' and page data, 
also contains page data. Image data- which is the actual 
data represented by page data, is stored in the data 
memory 80. 

The job control module 94 performs various control 
operations based on the job description file. The control 
this module performs includes print control, saved job 
print control, job description file editing control.job com- 
bination control, contents deletion control, archive con- 
trol, and restore control/ The job control module 94 
performs those control operation while referencing the 
contents management table 92. • 

Fig. 13 shows an example of the contents manage- 
ment table 92, The contents management table 92 
manages two types of contents, job description files and 
page data, equivalent)/ Column 130 contains the ID of 
each content. Column' 132 contains the unique ID 
assigned to each content. Column 134 contains the 
type of each content, that is, whether the content is a job 
description file or page data. Column 136 contains the 
contents ID of the parent contents associated with each 
content. Column 138 contains the number of parent 
contents. Column 140 contains the pointer pointing to 
the address within the JDF storage module 90 where 
the job description file is stored. Column 142 contains 
the pointer pointing to the address within the data mem- 
ory 80 where image data is stored. Columns 144 and 
146 contain page data attribute information. That is, 
they contain information about the color (black and 
while or color) and page size. The table also contains 
other attributes, as necessary, which are usually con- 
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tained in databases:. ■ 

The contents management table 92, JDF storage 
module 90, and data memory 80 may be created in the 
internal storage of the print control system 72. The 
attribute of each page, though stored in the contents s 
management table 92 in this embodiment, may be 
stored in a separately-provided page data storage mod- 
ule. In addition, though two components of page data 
(image data and attribute information) are separately 
stored in this embodiment, they may be managed by the 10 
same table.. 

Fig. 14 conceptually shows the relation among con- 
tents 1 - 5 stored in the contents management table 
shown in Fig. .-13. Contents ID1 represents a job 
description file. The job description f fle with the contents is 
ID1. whose ContentslDs field contains 2 and 3, refer- 
ences two items of page data, contents ID2 and con- 
tents 1D3, respectively. 

As shown in Fig. 14, the job description file with the 
contents ID 1 also references the job description file with 20 
the contents ID6 and, through that file, references two 
items of page data, contents ID4 and contents IDS. That 
is, these contents are hierarchically structured. It should 
also be noted that the job description file with the con- . 
tents ID7 references two items of page data, contents 2s 
ID3 and contents ID8. Column 136 in Fig. 13 contains 
the ID of the parent contents to show this hierarchical 
structure. This is the same for column 1 38.-. 

To execute a print job. in the. print control system l l: 
shown in Fig. 12, the job control module 94 reads the 3o : 
job description file from the JDF storage module 90 and, 
based on that file, controls printing. More specifically, 
the image data of each . page, which will be processed 
by the print job, is read from the data memory 80 for 
transmission to the de-compression module 96 for -35 
expansion. The image data is then, sent, /through the : ■ ; 
attribute adjustment module 98, to the page buffer 100. 
Then, the image data of each page is read . from .the . . * 
page buffer 100 and is sent via the data send module 
102, to the printer 104. The -print concfition is .set up « to 
according to the print attribute contained in the job 
description file and the page data of each page. 

The display 106 shown in Fig. 12 is a monitor dis- 
play on which the contents list or the job description f fl.e 
list is displayed. Also, in selecting the page data of a 45. 
page, the low-resolution data (image data) of each - 
page, created by the low-resolution data creation mod- 
ule 108, is displayed on the display .106. The low-reso- 
lution data creation module 108 creates low-resolution 
data using image data generated through job analysis, so 
The ability to display the image of each page in this 
manner allows the user to check (preview) the contents 
of each page before printing, making page selection 
easier. . . ••..> - 

The input unit 1 1 0 is a device such as a keyboard or 55 
a mouse. It is used, for example, for job description ffle -v 
editing or some other operations. 

The addition determination module 112 compares 
page data entered during a data restore operation with 



page data stored in the print control system 72. The 
module performs this comparison to enable only page 
data, not yet saved in the print control system 72, to be 
added. This operation will be detailed later. 

The send/receive module 114 controls the transfer 
of data to or from an external remote system. The exter- 
nal storage 116, usually a hard disk or a floppy disk, 
contains job description files and print jobs. This makes 
it possible for the user to write a job description file onto 
a portable medium and install it onto another system or 
-to read a job description file from another system via a 
portable medium. 

The archive information addition - module 118 
assigns archive information during archive operation 
(external saving). The retrieval module 120 uses 
archive information to retrieve data necessary for 
restore operation.- These modules will be described 
later. The color correction module 122 performs color 
correction on image data of a desired color when image 
data generated through job analysis is saved according 
to the color (CMYK). 

The blank page creation module 124 controls the- 
insertion of a blank page into a specified position during 
execution of a print job. The page number assignment 
module 1 26 inserts a page number into a specif ied posir 
tion on each page before printing it. 

The functions of the print control system 72 shown 
in Fig. 12 may be implemented by hardware units or by 
software modules. 

V. Operation j 

Fig. 15 shows the basic routines executed in the 
print control. system 72. The. basic routines are com- 
posed of the print routine S1 , saved job print routine S2, 
JDF edit routine S3, job combination routine.S4, con- 
tents deletion routine - S5, archive routine -S6,- and. 
restore routine S7, each of which is executed as 
required. The system basic routines are started when 
input data is received or when an operator, types a start 
request. 

(1) Print routicie - 

. Fig: 1 6,shows the.f lowchart of the print routine. This 
routine, will be described in the following with reference 
toFig; r 12. < 

The print routine is started when a print job or print 
fOe (JDF, JPF, JRF) is entered. A print job is coded in the 
page description language, created in the image file for- 
mat, or prepared in the text format. It is normally used 
as input for printing. 

In S101 - S103, the input data content determina- 
tion module 78, shown in Fig. 12, determines the type of 
input data. When a normal print job is entered, the job 
interpretation module 82 checks, in step 104, whether 
the hold option is specified before control is passed to 
the raster image processing (RIP) step (S106). That is,- 
the module checks, the hold timing option in the 
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HokJTiming field, 52, of the job description file shown in 
Fig. 4. If the field specifies that the print job should be 
saved before RIP, the module stores the print job in the 
data memory 80 and ends this processing. 

On the other hand, if the module finds, in step s 
S1 04, that the request to save the print job before RIP is 
not specified, it puts the print job in the RIP queue in the 
data memory 80 before interpretation. The job interpre- 
tation module 82 then interprets the print job and 
passes it to the RIP step where the job is expanded into to 
image data as shown in S106. Based on the job inter- 
pretation result, the JDF creation module 86 creates a 
job description file and, at the same time, extracts page 
data from the job analysis result. The compression 
module 84 compresses the image data contained in the is 
page data and stores the compressed image data in the 
data memory 80. The ID assignment module 88 assigns 
the contents IDs (JDF ID, page ID) and unique IDs to 
the job description file and page data. 'The job descrip- 
. tion file and the page data to which those IDs are - 20 
assigned are managed by the contents management 
table 92 as described above. 1 

In step 108, a check is made to determine if the 
HokJTiming field, 52, of the job description file (see Fig. 
4) contains the request to save the print job before print- 25 
ing and, if it contains such a request ends processing. 
If no such request is specified, printing starts under con- 
trol of the job control module 94 in S109 based on the 
created job description file. 1 That is, the module refer- 
ences' the job description file and reads necessary 30' 
image data from the data memory 80; decompresses it, 
and sends it to the printer 104. In this case, the print 
condition is set up according to the print attribute 
described in the job description file and page data. - 

In S110 in Fig. 16, a check is made to see if the 35 
JobSave field, 54, of the job description file (see Fig: 4) 
contains the request to save the before-RIP job. If no 
such request is specified, the before-RIP print job is * 
deleted from the data memory 80 by module S1 1 T: In 
S1 12, a check is made to see if the RipFileSave field, 4o 
56, of the job description file (see Fig. 4) contains the ' ' 
request to save the after-RIP job. If no such request is 
specified, the after-RIP job is deleted in S1 13. The con-' 
tents management table 92 is updated accordingly. ~ ' 

When a JDF print instruction file (JPF) is entered, 45 
the routine performs the* following processing/ 

If it is determined in S101 that the input is a JPF, the 
unique ID of the print job coded in the JDF print instruc- 
tion file is referenced to identify the job description file of ' 
the print job to be processed. In S1 15, the job control so 
module 94 reads the job description file and adds it as a 
job. After that, the job is processed as a print job as 
described above. 

When a job description file (JDF) is entered, the 
routine performs the following processing. ss 

When it is determined in S102 that the input is a 
JDF, there is a possibility that the print attribute speci- 
fied in the job description file has been changed. There- 
fore, a new contents ID as well as a new unique ID is 



assigned to the job description file in S116. The new job 
description file is then stored in the JDF storage module 
90 and added to the contents management table 92. 

When a new ID is assigned to the job description 
file, the unique ID of each content described in the Con- 
tentslDs field of the job description file is replaced by a 
contents ID used in this system. In this case, the con- 
tents management table 92 is referenced to identify the 
contents ID corresponding to the unique ID and the 
identified contents ID is then used for replacement 

In this case, if a content referenced in the Content- 
si Ds field of the job description file is not in the system, 
the routine searches the external storage 1 16 for rt. If it 
is not found there, the routine searches a remote sys- 
tem via the send/receive module 114. After the above 
processing, the same processing as that for a usual 
print job is performed. 

When a JDF revision instruction file (JRF) is 
entered, the routine performs the following processing. 

When it is determined in S103 that the input is a . 
JRF, the unique ID at the start of the JRF is referenced 
in S1 1 7 and the job description file with that unique ID is 
read. A check is made in S1 18 rf replacement pages are 
attached to the JDF revision instruction file. If no such 
page is attached, S121 is executed; otherwise, the job 
interpretation module 82 performs expansion on the 
attached pages to create page data containing image 
data. In S120, contents IDs and unique IDs are 
assigned to the created page data. The contents IDs ' 
written as $1 and $2 in the JDF revision instruction file 
are replaced with contents IDs used in the system and 
are reflected in the job description file. In addition, the 
unique IDs of the contents listed in the ContentslDs field 
of the JDF revision instruction file are replaced by the 
contents IDs used in the system based on the contents 
of the contents management table 92. At the same time, 
a new contents ID and a unique ID is assigned to the job 
description file and added to the contents management 
table 92 in S121. The request specifying whether to 
delete the original file is read from the JDF revision 
instruction file in S122; if the request to delete is speci- 
fied, the original job description file is deleted in S123. 
The subsequent processing is the same as that of a nor- 
mal print job. 

(2) Saved job print routine 

Referring now to Fig/12, the saved job print routine 
will be described below with reference to Fig. 1 7. 

The saved job print routine is started when the* 
operator enters an instruction to print a saved job. In 

5201, a list of saved print jobs appears on the display 
106 This list contains print jobs in the data memory 80 
waiting to be expanded as well as already-expanded 
print jobs each having a job description file and page 
data for each of its pages. 

When the operator enters a print request for a job in 

5202, the routine checks in S203 whether or not the job 
is already expanded. If it is expanded, the steps starting 
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with S208 are executed. If it is not. the routine first 
expands the job (interprets the job) in S204. In S205, 
the routine assigns the IDs to the job description file, 
created as a result of job interpretation, and to the page 
data of each' page in S205. The page data and the job $ 
description file are added to the contents, management 
table 92 in S206 and S207. In S208, the routine starts 
printing based on the job description file. TTie steps in 
S209 - S2 1 2 are the same as those of a normal print job 
shown in S1 10 -S1 13 in Fig. 16. . " . t , ." , . 10 

(3) JDF edit routine ■ ■ 

Referring now to Fig. 12, the JDF edit routine will be 
described below with reference to Fig. 18. TTie JDF edit 75 
mode is roughly classified into the "print attribute 
change mode" and the "print sequence change mode." 
The print sequence change mode is further classified 
into the "any-page-sequence print and multiple-copy 
print mode" and the "variable page print mode." 20 

First, the "print attribute change mode" will be 
described in the following. 

When the routine finds in S301 that the mode is the 
print attribute change mode, the display 106 displays in 
S302 a list of job description files currently saved in the 25 
system. When the operator selects a job description file 
through the input unit 1 10 in S303, the contents of the 
specified job description file are read. In S304, the oper- 
ator enters changes to any print attributes of the job 
description file. In S305, a new job description file is ere- 30- 
ated according to the change. In S306. contents IDs 
and unique IDs are assigned to the new job description 
file. In S307, the job description file is added to the con-, 
tents management table 92 . In this case, ^the operator 
enters an instruction specifying whether to delete the. 35 
original job description file in S308. A delete request, if 
entered, causes the original job description file to be. 
deleted in S309. ■ - = ■ * . . ■ * 

Next, the "any-page-sequence print and multiple- 
copy print mode", one of the print sequence change -ad 
modes, will be descrfoed in the following. 

When the routine finds that the mode is "any-page- 
sequence print and multiple-copy print mode" in S301 
and S310, it passes control to the routine, shown in Fig; 
19, in S3 1 1. In Fig. 19, the display 106 displays a list of 45 
job description files in S320. When, in S321 , the opera- 
tor selects a job description file to be edited, a list of the 
contents referenced by the job description file is dis- 
played in S322. The contents displayed include page 
data as well as other job description files included hier- 50 
archicaily in the job description file. 

In S323, the operator selects the contents to be 
printed in the sequence in which to print When the 
selection ends in S324, = the operator specifies the 
number of copies in S325. in S326, the routine checks if 55 
the operator's operation ends and, in S327, creates a 
new job description file according to the selection result, 
and then assigns contents IDs and unique IDs to the 
new job description file in S328. In S329, the routine 



adds the new job description, file to the contents man- 
agement table 92. 

When the operator specifies the number of print 
copies in S325 and, after that selects, the continuous 
mode without ending the operation, he can select con- 
tents and specify the number of copies again in the 
same manner as described above. This feature allows 
the operator to specify a variety pf print settings, (any 
number of copies of any contents). 

When the routine shown in Fig. 19 ends, control 
returns to S308 in Fig. 18. In this step, the original job 
description file is deleted if so specified. 

Referring now to Fig. 18. the /Variable page print 
mode" will be described in the following. 

When the routine finds that the selected mode is 
the variable page print mode, in S301 and S310, it exe- 
cutes S312 and passes control to the routine shown in 
Fig. 20. , - 

In S330, a list of saved job description files appears 
on the display. In S331, the variable "nest" is, initialized,, 
to 0. In S332, the operator selects a job description file,,* 
to be edited. Then, in S333, a list of contents referenced .. . 
by the selected job description file appears on the dis-^ 

In S334, the routine checks if a dummy page, ,:, 
described. later, will be used. If such a dummy page is -. 
used, the operator selects a position at which to insert- 
the dummy page in S335. lithe routine finds in S334, v 
that no dummy page will be used, it requests the opera- , « 
tor to select variable contents (described later) in S336... 
A dummy page is a blank page for insert printing, while.; 
a variable content is a page to be replaced. An example;, 
of how to use a dummy page and a variable content will 
be described later in detail. 

. In S337, a check js made to see if replacement con- 
tents : will,be specified by a directory. When specifying 
replacement contents.: with , a sfirectory, .the operator 
enters a^directory name. In S342, the routine checks if 
the operation ends. When the operation ends, an 
attribute such as the number of print copies is entered in- 
S343; In S344. the routine creates a new jdt) description . 
file based on the editing that has been done so far. In 
S345, f the routine assigns new contents I Ds.arxi unique 
IDs to the new job description file and, in S346, adds the. , 
new job description ffle to the contents management 
table 92. TTie routine then passes control to S308 in Fig.- 
18. Note that when, the operator selects to continue 
operation in S342, the steps beginning with S333 are 
repeated.- .„ . - ■ s - - . 1 

v When no directory is specif ied in S337, a list of job. 
description files is displayed in S338 to allow the opera- 
tor to select a contentto be replaced. In S339, the oper- 
ator selects a job description file from the displayed list. . 
In S340, the routine checks if the selected job descrip- 
tion file is a replacement content If the selected job 
description file is a replacement content, the routine 
checks, in S341, if the selection ends. The steps are 
repeated beginning with S339 if necessary. When the 
routine finds that the selection has ended in S341, the < 
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steps beginning with S342 are executed. 

On the other hand, if the operator specifies in S340 
that the selected job description file is not a replace- 
ment content but a content referenced by that job 
description file is a replacement' content, the variable s 
"nest" is incremented by 1 in S347 and the steps are 
executed beginning with S348. 

In S348, a list of contents contained in ContentslDs 
of the job description file selected in S339 is displayed. 
In S349, the operator selects a content and, in S350, 10 
the routine checks tf the selected content is a job 
description file. In S351 if it is a job description file, the 
routine checks if the selected job description file is a 
replacement content and, if so, checks in S352 if the 
operator has ended selection. If the operator has not yet 75 
ended selection, the routine repeats the steps begin- 
ning with S352. On the otherhand, if the operator spec- 
ifies in S352 that the operation has ended in S353, the 
routine decrements the variable "nest" by 1 and, in 
S354, ends the display of a list of contents. In S355, the 20 
routine checks if the variable "nest" contains 0. If the 
variable "nest" dose not contain 0, the steps are exe- 
cuted beginning with S348. If the variable "nest" con- 
tains 0, that is, if control returns to the initial job 
description file, the steps are executed beginning with 2s 
S341. 

In S351, if the selected job description file is not a 
replacement content, the variable "nest" is decre- 
mented by 1 in*S347 to execute the steps beginning 
with S348 to select the lower level contents. ■ ; 30 

The processing mode described above allows the * 
operator to specify a hierarchically-structured job 
description file or page data as a variable content and 
then to specify the number of print copies. As described 
below, the system prints pages while changing the 35 
sequence of contents according to the sequence 
selected as described above. 

Next, referring to Fig. 21 , the "print attribute change 
mode" will be described. • ' 

In Fig. 21 , (A)shows a job description file and the 40 
page data of each page. (B) shows the contents of the 
job description file with JDF ID 10. In this example, the 
job description file specif ies single side printing: Execu- ' 
tion of the job description file shown in (B) produces the 
pages printed in single-sided mode as shown in (C). 45 

(D) shows a job description file created by editing 
(modifying) the job description file with JDF ID 10 in the - 
print attribute change mode. In this job description file, 
the print mode has been changed from single-sided-to 
double-sided. Execution of this job description file pro- so 
duces the pages printed in double side printing mode as 
shown in (E). The use of the print attribute change mode 
allows the user to change any desired print attribute. 

Referring to Figs. 22 and 23, the "any-page- 
sequence print mode" will be described. ss 

Fig. 22 shows the state before file editing. That is, 
(A) shows the configuration of the print job and (B) 
shows the contents of the job description files (JDF ID 
10 and JDF ID 1 1) contained in the print job. Execution 



of the job description file with JDF ID 10 produces the 
pages printed as shown in (C). 

Fig. 23 (A) shows the job description ffle with JDF 
ID 12 which was created by changing the print method 
of the job description file with JDF ID 10 shown in Fig. 
22 (B). As shown in the figure, the last two in-file num- 
bers in the ContentsSelect field are changed and, there- 
fore, the pages shown in Fig. 23 (B) are printed in a 
different sequence. Because the content corresponding 
to the in-file number 8 is the job description file with JDF 
ID 1 1 shown in Fig. 22 (B), pages 8 and 9 precede page 
7. 

Fig. 24 shows an example of "multiple-copy print 
mode". As shown in Fig. 24 (A), the job description file 
with JDF ID 12 shown in Fig. 24 (A) was created from 
the job description file with JDF ID 10 shown in Fig. 22 
(B). In this job description file, the contents of the Con- 
tentsSelect field have been changed; that is, the 
number of print copies 10 and 5 are specified for each 
contents group. • 1 

Execution of JDF ID 12 prints 10 copies of pages 1, 
2, 5, 6, and 7, followed by 5 copies of pages 1, 2, 3, 4, 
8, and 9, as shown in Fig. 24 (B). 

Fig. 25 shows an example of a combination of the 
"any-page sequence print mode and the multiple-copy 
print mode". Execution of the print job JDF ID 12 shown 
in Fig. 25 (A) produces the pages printed as shown in 
(B). This print result may also be achieved by the "vari- 
able page print mode" described below. * 

Figs; 26 - 30 show some examples of printing in the 
variable page print mode. 

Fig. 26 shows the variable page print mode using • 
variable contents. As shown in Fig. 26 (A), the operator 
specifies a particular content from the list of contents 
shown on the display 1 06 as a variable content and then 
selects one or more replacement contents for this varia- 
ble content. Then, the job description file with JDF ID 10 
shown in Fig 22 (B) is changed and a new JDF ID12 is 
created automatically. 

Execution of a 'job description file shown in Fig. 26 
(B) produces the pages shown in Fig. 26 (C). The pages 
containing the variable content are printed first, followed 
by the pages where the variable content has been 
replaced by replacement contents. 

Fig. 27 shows an example of printing in the "varia- 
ble page print mode" using a dummy page. As shown in 
Fig. 27 (A), when the operator specifies a position at 
which a dummy page is to be inserted, a dummy page 
is inserted at that position. The operator then sequen- 
tially selects the replacement contents for the dummy 
page. As shown in Fig. 27 (B), this automatically creates 
a new job description file with JDF ID12 from the job 
description file with JDF ID10 shown in Fig. 22 (B). 

Execution of the job description file shown in Fig. 27 
(B) produces the pages shown in Fig. 27 (C). This is the 
same as that shown in Fig. 26 (C). 
A variable content itself appears in the first group, 
whereas a dummy page is not printed at all but is 
replaced by a replacement content « 
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Figs. 28 and 29 show some examples of printing in 
the "variable page print mode** in which a replacement, 
directory is used. As shown in Fig. 28 (A), with a partic- 
ular content as a variable content, the operator specifies 
replacement directory A containing a content which will $ 
replace the variable content. 

Also, as shown in Fig., 28 (B), the operator specifies 
a position at which a dummy page is to be inserted and, 
at the same time, replacement directory 6 containing a 
content to be inserted at that position. 10 

Fig. 29 (A) shows the contents of a new job descrip- 
tion file created automatically when a variable content 
and a dummy page are specified as shown in Fig. 28 (A) 
and (B). This job description file with JDF ID12 was cre- 
ated from the job description file with JDF ID1 0 shown in 75 
Fig. 22 (B). The same job description file is created for 
the examples shown in Fig. 28 (A) and (B). 

Execution of this job description file produces the 
pages shown in Fig. 29 (B). That is, when a variable 
content is used, the pages including that variable con- ,20 
tent are printed first, followed by the pages with the var- 
iable-content replaced with a content . from the 
replacement directory A, one at a time. ; 

This is the same for a dummy page.. That is, a con- 
tent is read from the directory B, one at a time, for inser- 25 
tion in the dummy page position. ....... 

Fig. 30 shows an example of printing in the "varia- 
ble page print mode" using a variable content group. 
With a list of contents on the display, as shown in Fig. 30 
(A), the operator specifies a variable content group and 30 
one or more replacement content groups. This variable 
and replacement contents, specified by the operator, 
automatically creates a new job description f jle with the 
JDF ID12 from the job description file JDF ID10 shown 
in Fig. 22 (B). This new job description file includes the 35 
changes specified by the contents groups shown in Fig. 
30(A): . 

Execution of this job description file produces the 
pages shown in Fig. 30 (C). That is, the pages contain- 
ing the variable contents group are printed first, followed . 40 
by the pages with variable contents replaced sequen- 
tially by other, contents groups. 

As described above, this embodiment gives the 
user the job description file editing function enabling him 
to print data in a variety of ways while allowing him to re- 45 
use saved page data unchanged. ■ ■ 

(4) Job combination routine 

Referring now to Fig. 12, the following explains the so 
job combination routine with the use of Fig. 31. When 
the operator selects a job combination, a list of saved . 
job description files appears on the display in S401. In 
S402, the variable "nest* is initialized to 0. 

In S403, the operator selects, via the input unit 110, 55 
a job description file containing content to be combined . 
into the original job description file. In S404, the opera- 
tor checks if the selected job description file is a content - 
to be combined; if so, he specifies in S405 whether to 



continue selection. • . 

When the operator specifies that selection be con- 
tinued, the steps beginning with S403 are executed. On 
the other hand, when the operator specifies that selec- 
tion be ended,- he enters the attributes such as the 
number of print copies in S406. In $407 a new job 
description file into which selected contents are com- 
bined is created. In S408, contents IDs and unique IDs 
are issued to the new job description file and, in S409, 
the new job description file is added to the. contents 
management table 92. In S410, the routine asks the 
operator whether to delete the original job description 
fOe. The routine deletes the original job description file 
in S41 1 if so requested by the operator. 

If, in S404, the operator specifies that the selected 
job description file not be combined, the variable "nest" 
is incremented by 1 in S414 and the steps beginning 
with S41 2 are executed. 

In S412, a list of contents contained in the selected 
job description file is displayed. In S413, the operator 
selects a content from the list via the input unit 110. The 
operator checks if the selected content is a job descrip- 
tion file or page data in $41 4. ff it is a job description file, 
the operator checks, in $41 9, if the selected job descrip- 
tion file is to be combined. If the operator specifies that 
the job description file is to be combined, the routine 
asks whether to end the selection in S415. If the opera- 
tor specifies that the selection.be continued, the steps 
beginning with S413 are executed. On the other hand, if 
the operator specifies that the selection be ended, the- 
variable "nest" is decremented by 1 in S416 and, in 
S417,a list of contents disappears. In S418, a check is 
made to see if the variable. "nest" contains 0. The value 
of 0, if stored in the variable "nest", means that control 
is returned to the first level of the hierarchical structure. 
In this case, the steps are executed beginning with 
S405. 

ff r in.S419 the operator specifies that the selected 
job description file not be combined, the variable "nest" 
is incremented by 1 in S420 and the steps are executed 
beginning with,S412.r:* 

The abpve steps, eventually find a content to be 
combined within the hierarchy, and a new. job descrip- 
tion filecontaining that content is created. 

. Referring.now to Fig. 32, an example of job combi- 
nation will.be described. ; .. > . • .! / 

Fjg ; 32 (A);shows the configuration of a print job 
used in* this .example. This print job has- three? job 
description files and seven pages of page data. Fig. 32 
(B) shows the contents of each job' description file. In 
this situation, if the page data with the page ID4 and the 
job description file with the JDF ID1 2 are combined into 
the job description file with the JDF ID10, a new job 
description file with the JDF ID13 is created as shown 
Fig. 32(C). Fig. 32 (D) shows the pages produced by 
executing the new job description file containing com- 
bined contents. 
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(5) Contents deletion routine 

Referring now to Fig. 12, the following explains the 
contents deletion routine with the use of Fig. 33. This 
contents deletion routine is executed when the operator s 
enters a contents deletion request from the input unit 
110. As described below, whether to delete contents 
depends on the reference relationship among the con- 
tents. 

When the operator instructs the routine to delete 10 
page data described in a job description file, the routine 
confirms, in S501, that page data is to be deleted, and 
references the contents management table 92 in S502 
to check if another job description file references the 
page data. If no job description file references the page is 
data, the routine deletes the page data from the data 
memory 80 in S503, changes the relevant fields (Con- 
tents IDs, ContentsSelect) of the current job description 
file in S504 to update it In S505, the routine updates the 
contents management table 92. On the other hand, if it 20 
is found in S502 that there is another job description file 
referencing the page data, the routine does not delete 
the page data and, in S504 and S505, updates only the 
job description file and the contents management table. 

When the operator instructs the routine to delete a 25 
job description file, the routine confirms, in S501, that 
the job description file is to be deleted and initializes the 
variable "nest" to 0 in S506. In S507, the routine checks 
if the check has already been made to see if it is possi- 
ble to delete all the contents from the job description file. ' ' 30 
If the check is not yet made, the routine checks if the 
content to be checked is a job description file in S508. If 
the content is page data, the routine checks, in S509, if 
another job description file references the page data. If 
there is no such job description file, the routine deletes 35 
the page data in S510 and, at the same time, updates 
the contents management table 92 in S511. On the 
other hand; when it is found in S509 that another job 
description file references the page data, the routine 
does not delete the page data but only updates the con- 40 
tents management table 92 in S51 1 . The processing" is ' 
then repeated beginning with S507. 1 ^ ! 

If it is found in S507 that the check has already ' 
been made for all the contents of the job description file 
to be deleted, the routine checks, in S512, if there is a 45 
parent job description file referencing the job description ■' - 
file to be deleted. If there is no such job description file, 
the routine deletes the job description file in S51 3, while - 1 
if there is such a job description file, the routine does not 
delete the job description file and ends processing.' so 

In S508. if it is found that the job description file to 
be deleted contains another job description file (child ' 
job description file), the routine executes the steps' 
beginning with S520 to check the contents contained in 
that child job description file. ' ss 

First in S520, the routine adds the contents ID of 
the job description file; found in S508, to the nest list, in 
this case, the routine adds the contents ID of the job 
description file to be deleted as the 0-th entry of the nest 



list and adds the contents ID of the job description file 
found in S508 as the nest-th entry. In S521 , the variable 
nest is incremented by 1 . 

In S522, the routine checks if the variable "nest" 
contains 0. If it does not contain 0, in S523 the routine 
references the nest-th job description file in the nest list 
to check the contents contained in that job description 
file. ' 

In S524, the routine checks if all the contents have 
been examined and, in S525, checks if the content is a 
job description file. If it is found in S525 that the content 
is a job description file, the steps are executed again 
beginning with S520. On the other hand, if it is found 
that the content is page data, the routine checks, in 
S526, if there is another job description file referencing 
the page data. If there is no such job description file, the 
routine deletes the page data in S527 and updates the 
contents management table 92 in S528. If it is found in 
S526 that there is a job description file referencing the 
page data, the routine does not delete the page data but 
updates the contents management table 92 only. The 
steps beginning with S524 are repeated. ; 

ff it is found in S524 that all the contents referenced 
by the nest-th job description file have been examined, 
the routine checks, in S529, if there is another job 
description file (other parent job description file) refer- 
encing the job description file. If there is no such job 
description file, the routine deletes the job description 
file in S530 and updates the contents management 
table 92 in S53T. On the other hand, if it is found in S529 
that there is another job description file referencing the 
job description file, the routine does not delete the job 
description file but updates only the contents manage- 
ment table 92 in S531 . The routine then deletes the con- 
tents ID of the nest-th job description file from the nest 
list, decrements the variable "nest" by 1 in S533, and 
repeats the steps beginning with S522. When ail the 
contents are checked, control is passed from S522 to 
S507. > 

As described above, the contents deletion routine 
deletes page data only when there is no job description 
file referencing the page data. And; the routine deletes 
a job description file* only when the contents of that job 
description file are not referenced by another job 
description file. This allows the operator to delete con- 
tents even when they are shared. 

Fig. 34 shows an example of contents deletion. (A) 
shows the job configuration, and (B) shows the contents 
of each, job description file. 

Assume that page data with contents ID2 is deleted 
from the job description file with JDF ID10 and that the 
job description file with the JDF ID12 is deleted. 

This deletion results in the job description file JDF 
ID10 being changed as shown in (C), and the job con- 
figuration as shown in (D). That is, page data with con- 
tents ID2 and the job description file with JDF ID1 2 have 
been deleted. : . 
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(6) Archive routine r . - 

Referring now to Fig. 12, the following explains the 
archive routine.with the use of Fig. 35. 

When the operator requests execution of archiving 
via the input unit 1 10, the archive routine shown in Fig. 
35 is executed. The operator can select one of three 
archive modes: job basis archive, job description f3e 
basis archive, and all data archive. ; — ^ 

When the operator selects the job basis archive, 
mode, he enters archive information from the input unit 
110 in S601. .The archive information the operator 
enters includes comments, keywords, etc. The archive 
execution date is automatically included in the archive 
information. Old archive information, if any, is overwrit- 
ten. This archive information is used to check the com- 
ments or to retrieve keywords when the archive data in 
external system is restored to the local system. 

When the routine finds that the operator has 
selected the job basis archive mode in S602 and S603, 
it updates the job description file in S607. More specifi- 
cally, it changes the content IDs contained in the Con- 
tentslDs field of the job description file to the 
corresponding unique IDs. In this case, the routine ref- 
erences the contents management table 92 to identify 
the correspondence between content IDs and unique 
IDs. 

In S608, the routine saves the updated job descrip- 
tion file in the external storage 116. At this time, the rou- 
tine also sends all the contents in the first hierarchical 
level in that job description file to the external storage 
116. * ■ .. . , . 

In S609, if -the first hierarchical level content con-, 
tains a job description file, the routine sends the content 
contained in that job description file, recursively to the 
external storage 116: As a result alt the data pages 
required for the print job to be executed are sent to the 
external storage 1 16. For the data pages in the second 
level or higher, only data is sent and IDs are not 
changed. 

In S610, the routine checks the archive mode to 
see if it is the copy mode or the move mode. In the copy 
mode, the job description file to be archived and all the 
contents referenced by the job description file are cop- 
ied, with, the contents in the internal storage saved 
unchanged. In the move mode, out of the contents in the 
first hierarchical level referenced by the job description 
file to be archived, only the page data not referenced by 
another job description file is deleted from the internal . 
storage, as shown in S611, and in S612, the contents 
management table 92 is updated. When the content is a 
job description file, it is not deleted. 

When the operator requests to archive only a job 
description file, the routine finds, in S602 and S603, that 
the operator has selected the job description file basis 
archive mode and, in S604, sends the job description 
file with archive information to the external storage 116. 
In this case, the routine changes the contents IDs con- 
tained in the job description file to the corresponding 



unique IDs and saves the changed job description file in 
the external storage 116 in S605. In S606, the routine 
updates the contents management table 92. It should 
be noted that in the job description file basis archive 

5 mode, only the copy mode is used. The operator cannot 
select between the copy mode and the move mode as in 
the job basis archive mode. 

When the operator requests to archive all the data 
(system backup), he enters archive information in S601 

.10 as described above. In this case, archive information is 
created and stored as a file. In S602, the routine finds 
> that the operator has selected the all job archive mode 
and sends all the page data and all the job description 
ffles from the internal, storage to the external storage 

is 1 16 in S61 3. In this case, the routine also saves archive 
information. The routine does not change contents IDs 
to unique IDs. In $614, the operator selects the copy 
mode or move mode. In the copy mode, the processing 
ends; in the move mode, all the data (page data and job 

20 description file) is removed from the internal storage in 
S61 5 and the contents management table 92 is cleared 
inS616. 

Referring now to Figs. 36 - 38, an example of 
archiving will be described. - 
25 Fig. 36 shows the state before archiving. (A) shows, 
the job configuration, and (B) shows the contents of the 
job description ffles contained in the job. 

In .this situation, assume that the operator has, 
selected the job basis archive mode for the job descrip^v 
so- tion file with JDF ID10. Then, as shown in Fig. 37 (A), . 
the job description file is updated. That is, the contents ? 
IDs are changed to the corresponding unique IDs. Fig. , 
37 (B) shows .the job description files that have been 
archived with the contents referenced. Fig. 38 shows 
, 35 the state in which the system has been backed up under . 
the condition shown in Fig : 36.. 

Fig. 39 shows the relationship between a local sys- 
tem where the print control system is installed and the 
external; storage onto which contents are archived. 
40 When , the Job; description file basis, archive mode is 
selected, the job description file with the contents ID10 
is archived on the external storage. The job description 
ffle is managed by the unique ID. 

Fig; 40 shows an example of archive information. 
45. The operator may specify this archive information in 
each archive, operation. In this example, the archive 
information includes a . comment keyword; and save 
- date. / - 

50 (7) Restore, routine - 

Referring now to Fig. 12, the restore routine will be 
described with the use of Figs. 41 - 43. 

The restore operation, the reverse of the archive 
55 j operation, also has three modes: job basis restore, job 
* description file (JDF) basis restore, and all job restore 
(restoration of backup data). When the operator selects 
one of these restore modes, the restore routine shown 
in Fig. 41 is started. 
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First the restore operation in the job description file 
basis mode will be described. In this mode, the routine 
restores a job description file contained while restoring 
a job. In S701 , when the routine finds that the operator 
has selected the job basis restore operation Qob 5 
description file basis restore included), the operator is 
requested to select a job Gob description file) in S702. 
Via the display 106, the operator selects a job descrip- 
tion file from a list of archived jobs Qob description files) 
saved in the external storage 116. The retrieval module 
120 searches for the selected archived job with a com- 
ment or an archive date as the key. Of course, the oper- 
ator may specify a keyword to select a particular job. 

When the operator selects a job description file, the 
routine finds, in S703, that the operator has 1 selected the 
job description ffle basis restore mode and copies the 
archived job description file from the external storage 
116 to the internal storage (JDF storage module 90). 
Before this, the routine assigns a unique ID to the job 
description file in S704, updates the job description file 
with this ID in S705 and, saves the job description file in 
the internal storage in S706. At the same time, the rou- 
tine adds the job description file to the contents man- 
agement table 92 in S707. 

Execution of a restored job description file requires 
that all the contents contained in the ContentslDs field 
of the job description ffle be present in the print control 
system. The routine performs the following processing 
to ensure that this is the case: 

In S708, the routine checks if all the contents (child 
contents) contained in the restored job description file 
(parent content) have been checked. In S709, the rou- 
tine checks if the contents management table 92 con- 
tains the unique IDs of the child contents! The addition 
determination module 112 shown in Fig. 12 performs 
this processing: 

If it is found in S709 that the unique ID of a child 
content is in the table, the contents management table 
92 is updated in S710. More specifically, in the contents 
management table shown in Fig. 13, the contents ID of 
the restored parent content is added to the ID field, 1 36, 
of the parent content corresponding to the child content. 
At the same time, in S71 1, the unique ID contained in 
the ContentslDs field of the parent job description file is 
changed to the contents ID of the child content con- 
tained in the contents' management table 92. Note that' 
a child content that is present during a restore operation 
is not copied. 

If it is found in S709 that the unique ID of the child 
content is not in the contents management table 92, 
control is passed to S712. That is, the routine shown in . 
Fig. 42 is executed. 

In S750, the routine initializes the variable "nest" 
indicating a hierarchical level to 0. In S751, the routine 
examines sequentially the remote systems connected 
to the network and searches the contents management 
table 92 of each remote system for the unique ID of the 
child content. If no remote system contains the child 
content, the routine ends processing; if a remote system 



contains the child content, the routine checks, in S752, 
rf the content is a job description file or page data. 

If the child content is page data, the routine copies 
the page data from the remote system to the internal 
storage in S753. At this time, the routine assigns a con- 
tent ID to the child content. In S754, the routine adds the 
page data, the child content, to the contents manage- 
ment table 92. 

In S755, the unique ID of the child content con- 
tained in the ContentslDs field of the job description file, 
the parent content, is changed to the content ID 
assigned by the print control system. For page data 
copied from the remote system, the unique ID is used 
unchanged. Only the content ID is changed to the con- 
tent ID used in this print control system (local system). 

If it is found in S752 that the child content is a job 
description file, the routine sends the job description file, 
the child content, from the remote system. In the remote 
system, the content ID in the ContentslDs field of the job 
description file is changed to the unique ID before the 
job description file is sent. 

In S756, the routine assigns a new unique ID to the 
job description file sent from the remote system and, in 
S757, saves the job description file in the internal stor- 
age. At the same time, the routine assigns the content 
ID of this print control system to that job description file 
and, in S758, updates the contents management table 
92. That is, it adds the transferred job description file to 
the contents management table 92. In S759, the unique 
ID contained in the content ID of the job description file, 
the parent content, is changed to the content ID of this 
print control system. 

Then, the routine repeats the above steps to copy 
all the contents (job description files and page data) 
required for the execution of the job description file, the 
parent content. That is, the routine goes down to a lower 
hierarchical level to continue the search of each content 
until the reference relationship is resolved. In Fig. 42, 
this is represented by S800. In fact, repeated execution 
of S801 to S815 collects the child contents to be refer- 
enced by the parent content. 

In Fig. 41, when carrying out the job basis restore 
operation, the routine performs almost the same 
processing as for the above-mentioned job description 
file basis restore operation. That is, the steps S704 - 
S71 1 and the steps S720 - S727 are basically the same. 
If it is found in S725 that the unique ID of the child con- 
tent is not in the contents management table 92, . the 
routine passes control to S728 to execute the routine 
shown in Fig.43. 

The job basis restore operation is the reverse of the 
job basis archive operation. Therefore, all the child con- 
tents specified for a parent content are archived in 
external storage 116. If a child content is not found in 
the local system in S725, the child content is copied 
from the external storage 116. More specifically, after 
executing S770, in S771 the routine checks if the child 
content is a job description file. If the child content is 
page data, the routine sends the page data from the 
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externa! storage 116 and saves it in the internal storage. 
At this time, the routine assigns the content ID used in 
the local system to the child content and, in S773, adds 
the child content to the contents management table 92. 
In S774, the unique ID of the child content contained in 5 
the ContentslDs field of. the job description file, which is 
the parent content, is changed to the content ID that 
was assigned as described above. 

If it is found in S771 that the child content is a job 
description ffle, the routine assigns a new unique ID to 10 
the child content (job description .file) in S775 and, in 
S776, saves the job description file from the external 
storage 1 16 to the internal storage. In steps S777 and 
S778, the same processing as for S773 arid S774 is 
executed. 15 

The routine; indicated by S900 searches for the 
grandchild contents referenced by the parent content 
via the job description file (which is the child content) 
and for lower hierarchical level contents as necessary. 
The steps S901 to S917 copy alkthe contents, refer- 20 
enced by the parent content directly and indirectly, into . 
the internal storage. Of course, the routine does not add 
a content already in the internal storage. . For this type of . 
content, the routine only updates the contents manage- ; 
ment table 92 and changes the unique ID of the job 25 
description file to the content ID. 

Referring again to Fig. 41 , the backup data restore 
operation will new be described. If it is found in S701 
that the operator has. selected the backup data restore .. 
operation, control goes to S740. The display 106 dis- t 30 
plays backup data as well as archived archive informa- 
tion to allow the operator to select which backup data to 
restore. Of course, the retrieval module- 120 searches 
for backup data with a comment or an archive: date in 
archive information as the search key. Alternatively, the 35 
operator, may specify, a keyword to search for backup 
data. It should be noted that only one. block of backup., 
data may be specified in the backup data restore opera- 
tion. 

In S 741, the routine deletes all the job description -40 
files and page data from the internal storage before . , 
starting the backup data restore operation and, at the 
same time, clears the contents management table 92 in , 
S742. In S743, the routine copies all the backup data 
from the external storage 1 1 6 to the internal, storage. In 45 
this case, the content IDs and unique IDs of the con- 
tents are used unchanged and, in S744, the contents 
management table 92 is created. That is, the state at 
the time of backup is re-produced. . • 

Referring to Figs. 44 - 47, an example of the above- so 
mentioned restore operation will be described. 

Figs. 44 and 45 show an example of the job basis , 
restore operation. Fig. 44 (A) shows the contents, 
present in the system and in the archive storage. Fig. 44 
(B) shows the contents of the job description file with 55 
JDF ID11 stored in the system. Fig 44 (C) shows the 
contents of the job description file with the unique ID 
95100111101012345ab600010. Fig. 44 (D) shows the 
unique IDs of page data referenced by JDF ID1 1 . 



When restoring a job from the archive storage in 
this situation, a new content ID, JDF ID12, used in this 
print control system, is assigned to the job description 
ffle and, at the same time, a new unique ID 
960301 1010212345ab600012 (restore date and time: 
10:1050 on March 1st, 1996, host ID: 12345ab6, JDF 
ID12) is assigned. During restoration, the system refer- 
ences the ContentslDs field of the; job description file to 
be restored to check for a content with a unique ID that . 
is also found in the system, and restores, in conjunction 
with the job description file, only those contents whose 
IDs are not found in the system. In the example shown 
in Fig. 44, because the unique ID of the content 9..2 
(page data) in the archive storage is equal to the unique 
ID of the page ID2 in the system, this content is not 
restored. Only the content 9.. 1 (page data) in the 
archive storage is restored with the job description file. 
Fig. 45 shows the. result. (A) shows the job description 
fae created by restoring the job description file from the 
archive storage, and (B) shews the content configura- 
tion within the system. As shown in this figure, a new 
content I D5 is assigned to the page data with the unique, 
ID 9..1 which was in the archive storage. 1 Ht 

Then, referring to Figs. 46 and 47, the following 
explains an example of job description file basis restore 
operation. 

Fig. 46 (A) shows the contents stored in the archive 
storage such- as a remote . system or external storage. 
Assume that the job description file with JDF ID1 1 in the 
remote system is the same as the job description file 
with unique) ID9.. 11 in the archive storage., Fig. 46 (B) 
shows the. contents of the job description file stored in 
the archive storage, and Fig. . 46 (C) shows the, unique 
IDs of page ; data stored in the remote system. 

When restoring the job description file from the, 
archive storage to the local system (print control sys- 
tem) in this situation, the local system checks if it has 
the cqntents : -referenced by the job description, file. 
Because there is no such content in the example shown . 
in the figure, the system first, searches the archive stofr 
age for the contents- Because the archive storage does 
not contain the contents either, the system searches.the 
remote system for. the contents. Because Jhat remote 
system has the contents, they are restored in conjunc- 
tion with the job description file. 

Fig. 47. (A) shows the contents of the job description 
file restored with the new^content ID and unique ID, and 
Fig. 47 (B) shows the content configurations of the local 
system, remote system, and archive storage. As shown 
in the*figure, when the job description .file is restored 
from the archive storage, page data referenced by that 
job description file is also restored. 

(8) Other functions; 

Referring to Figs. 48 to 51 , the function of the Medi- 
aPrecedence field, 42, shown in Fig. 4 will now be 
described. Fig. 48 (A) shows the contents saved in the 
internal storage, and Fig. 48 (B) shows the contents of 
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the job description files. Assume that pages ID1 to ID7 
contain page data of the page sizes and paper orienta- 
tions as shown in Fig. 49. 

Execution of the job description file with JDF ID13 
shown in Fig. 50 (A) under this condition produces the s 
result shown in Fig. 50 (B). That is, the job description 
file with JDF ID1 3 contains "page" as the attribute prec- 
edence information (indicated by 152). Therefore, the 
page data has priority over the job data with respect to 
the paper size and orientation indicated by 1 50. On the 10 
other hand, execution of the job description file with JDF 
ID14 shown in Fig. 51(A) under the condition shown in 
Figs. 48 and 49 produces the result shown in Fig. 51 
(B). That is, "job" is specified as the attribute prece- 
dence information (indicated by 154), meaning that if 75 
the print attribute in the job description file does not 
match the print attribute in the page data, the attribute 
specified in the job description file has priority. Because 
"A4 Portrait" is specified in the job description file in this 
case, all the pages are printed in the A4 size and in the 20 
portrait format. 

The attribute adjustment module 98 shown in Fig 
1 2 allows the user to adjust the print attribute as neces- 
sary. For example, the attribute adjustment module 
allows the user to enlarge, reduce, or rotate images. 25 

Fig. 52 shows the blank page creation module 124 
and the page number assignment module 1 26 shown in 
Fig. 12. 

When the'print job JDF ID13 shown in Fig. 52 is 
executed under the condition shown in Figs. 48 and 49, 30 
the blank page creation module 1 24 enables the user to 
specify a location at which a blank page is to be inserted 
and the page number assignment module 126 to insert 
a page number on each page. In this case, the user can 
specify various page number assignment conditions 35 
such as whether to assign continuous numbers or ; 
where the page number is positioned. Execution of the 
job description file with JDF ID13 with other additional ' 1 
attributes specified produces the result shown in Fig.v ' 

52. >r 40 

Fig. 53 shows the color correction module 122 
shown in Fig. 12. Although one unit of image data is cre- 
ated in each page in the above embodiment as shown in 
(A), page data- may be created for each of CMYK- as 
shown in (B). In addition, as shown in (C), color correc- 45 
tion may be carried out individually for the page data of 
a desired color. 

VI. Other Embodiment 1 - 

'50 

(1) Although, in the above embodiment, data 
expanded through job analysis is used in job com- 
bination, a print job not yet expanded through job " 
analysis may also be combined into another job. 
When a print instruction is issued to a combination ss 
job containing a job not yet expanded, the job not 
yet expanded is expanded before printing. 

It is desirable that some print jobs, which do not 
require much time for expansion, be saved in a for- • 



mat which does not require much space, for exam- 
ple in the PDL format rather than in a large image 
data format. In addition, a print job may be com- 
posed of low-expansion-load text image pages and 
high-expansion-load high-resolution picture image 
pages. In this case, it is possible to divide a job into 
a part before expansion and a part after expansion. 

(2) In the above embodiment, data stored in the 
internal storage is deleted by an operator's instruc- 
tion. However, it is also possible to delete data auto- 
matically when the amount of data in the internal 
storage has reached a specified amount or a spec- 
ified ratio. In this case, data may be deleted in order 
of creation dates or in ascending order of data 
importance with a function set importance to jobs. It 
is also possible to automatically move data into the 
external storage when the amount of data has 
reached a specified amount or a specified ratio. 
When the amount of data in the internal storage 
has reached a specified level, a warning message 
may be issued to the operator. 

The above-mentioned embodiment prevents a 
system error which will be caused when the internal 
storage has run out. 

(3) Although the above-mentioned embodiment has 
only one job analysis module, a plurality of job anal- 
ysis modules may be provided. Such a configura- 
tion allows concurrent processing to be performed 
on a job on a page basis or a plurality of jobs to be 
executed concurrently. ' ... 

In general, the expansion of a print job into 
raster data is a performance bottleneck in a print 
control system. The other components of the print 
control system are sometimes idle simply because 
it takes a long time for this processing to complete. 
The above-mentioned configuration increases effi- 
ciency through concurrent processing and ensures 
the overall productivity of the print control system. 

VII. Other Embodiment 2 (Job Combination) 

The ContentsSelect field in a job description file 
enables the user to print any pages in any sequence, as 
shown in Rigs. 24 and 25. As shown in Fig. 54 (A), 
assume that ContentslDs in a job description file con- 
tains- 

ContentslDs :1, 2,3.4,5,6,7,8,9,10 
and that ContentsSelect contains * * / 

ContentsSelect : [1 [1 ,2,3,4,5,6,7,8,9, 1 0]]. 
Then, execution of the job description file produces the 
pages shown in Fig. 54 (B). 

In the print result, page 1 is "preface", pages 2 and 3 are 
"contents", pages 4 - 6 are "overview", and pages 7-10 
are "text": Also, assume that ContentslDs as shown in 
Fig. 55(A) contains the same as described above and 
that ContentsSelect contains the following : 

ContentsSelect : 
[3[1 ,2,3],2[1 ,4,5,6],3[1 ,7,8,9.10]]. 
Then, execution of the job description file, job A, pro- 
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duces the pages shown in Fig. 55 (B). 

That is. in ContentsSelect, the print sequence is 
specified in "[ fusing in-file numbers identified by the 
order in which pages are specified for the ContentsIDs 
field. The number of copies precedes 1 ] n . Therefore, s 
three copies are printed for the top set in Fig. 55 (B), two 
copies for the middle set, and three copies for the bot- 
tom set. 

This description format allows the user to specify 
the number of copies of each set, one set being com- 10 
posed of a plurality of pages. This is what we call selec- 
tive binding. Fig. 55 (B) shows an example of a selective 
binding print result. A variety of page configurations are, 
possible in a single job. 

For example, in a mail order sale, the type of prod- is 
uct information varies from customer to customer. In this 
case, the mail order sales company sends a catalogue 
composed of a cover, order instruction page, and a 
group of product information pages. In such a case, the 
company will find selective binding ideal for producing 20 
any number of copies each of which consists of pages 
necessary for each customer. 

In creating a new combination job by combining a 
job containing selective binding descriptions into 
another job, how to specify selective binding is impor- 25 
tant. The embodiment described below is intended to 
solve thisproblem. 

The job control module 94 shown in Fig: 12 per- 
formsjob combination,' that is, it combines a plurality of. 
job description files into a new job description file. There 30 
are three combination modes: (i) condition maintenance 
mode in which the selective binding condition is used 
unchanged, (ii) partial condition usage mode in which 
the selective binding condition is partially used, and :(iii) 
condition clear mode in which the selective binding con- 35 
dition is cleared. The user can select one of the modes 
as well as the job combination condition. 

The following explains each mode: . 

In the following explanation, the jobs are combined 
in order of job B (Fig. 56), job A (Fig. .55), and job C (Fig. 40 
57). For simplicity, assume that ContentsIDs of each job 
description file does not contain a job description file. 

In the condition maintenance mode (i),.a new job 
description file is created for combination job Las 
shown in Fig. 58 (A) and the print result of combination as 
job 1 is as shown in Fig. 58 (B). In ContentsIDs of the 
newly-created job description file, the components of 
job B and job C are added to the components of job A. 
The new in-file numbers appear in ContentsSelect 
accordingly. ■ ^ so 

In this mode, the print method in described Con-- 
tentsSelect in job A, shown in Fig. 55, is basically main-, 
tained. That is, each page set enclosed by [ ]-. is 
preceded by job B and followed by job C. New compo- 
nents are added to the page configuration of each set, ss 
with no change in the number of sets or the number of 
copies. Comparing Fig. 55 (B) with Fig. 58 (B) indicates 
that, in the first set, page 11 of job B is. added at the • 
beginning and pages 12 and 13 of job C are added at 



the end. This js. the same as in other, sets. That is, in 
sets 2 and 3, page 1 1 of job B is added at the beginning 
and pages 12 and 13 are added at the end. 

The user may specify a job to be used as the base 
(a job whose print method is used) of a plurality of jobs 
to be combined. If selective binding is specified only for 
one job, that job may automatically become the base 
job; if selective binding is specified for a plurality of jobs, 
the user may select one of them. , 

In the partial condition usage mode (ii). a combina- 
tion job such as job 2 shown in Fig. 59 is used. As 
shown in Fig. 59 (A), the two sets put of three sets (mid- 
dle set excluded) contained in ContentsSelect of job A 
are used, preceded by the pages of job B and followed 
by the pages of job C. Fig. 59 (B) shows the print result 
of combination job 2 in this mode. 

The user may specify a combination condition eas- 
ily (e.g., which set to use or in which sequence jobs are 
to be combined), and the job description file of a combi- 
nation job is created automatically according to what the 
user has specified. 

In the condition clear mode (iii), a combination job., 
such as job 3 shown in Fig. 60 is used. As shown in Fig. 
60 (A), the selective binding conditions are cleared, and 
set conditions and the number of copies are released. 
Fig. 60(B) shows the print result of combination job 3. 

The user may select, for example, any combination 
mode via the input unit 1 10 shown in Fig. 12. When the ; 
user selects a mode on the input unit 1 10, the job con- 
trol module 94 executes job combination according to 
the selected mode. 

In this embodiment, the user can combine jobs 
including those for. which selective binding is specified: 
The combination mode is selected according to the- 
user's request The condition maintenance mode (i). 
allows, the user to use a selective binding condition 
unchanged, eliminating the need to set up a condition 
and thereby increasing operability. The partial condition 
usage mode (ii) allows the user to use a part of a selec- 
tive binding condition, thus increasing operability. The 
condition clear mode (HO is useful for discarding an old 
selective binding condition and for creating a new one. 

In the, partial condition usage mode (ii). an unused 
selective, binding condition may - be extracted and 
defined as another job. This function enables the user to 
configure a system allowing hirrhto divide or combine 
jobs easily. ■ - * 

In a print system with a finisher for binding, finishing 
processing may be controlled automatically according 
to the number of pages of each set for which selective 
binding is performed. For example, when the number of 
pages of a set is 50 or less, a stapler is used When the 
number of pages is larger, simple binding is used. This 
control function controls the finisher operation automat- 
ically and, in particular, resolves selective binding com- 
plexities. 

As described above, the system according to this 
invention allows the user to manage print jobs on a job 
basis as well as on a page basis, giving him a variety of 
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functions. In particular, the ability to share common print 
data among a plurality of print jobs increases data 
processing and data storage efficiency. In addition, the 
system gives the user many functions including print job 
concurrent binding, print job hierarchical binding, page 5 
addition, page replacement, and page deletion. Ail 
these functions make it possible to build a highly useful 
print control system. 

While there have been described what are at 
present considered to be preferred embodiments of the 10 
invention, it will be understood that various modifica- 
tions may be made thereto, arid it is intended that the 
appended claims cover all such modifications as fall 
within the true spirit and scope of the invention. 

15 

Claims 

1 . A print control system comprising: 



2. A print control system according to claim 1 , further 
comprising a job interpretation module interpreting 
a received print job to create said job description file 
and said page data. 35 

3. A print control system according to claim 1 , further 
comprising an identification information assignment 
module assigning identification module to said job 
description file and said page data, wherein said 40 
job description file and said page data are man- 
aged by said identification information. 

4. A print control system according to claim 3, wherein 
said identification information assignment module 45 
assigns, as said identification information, local 
identification information known within the print 
control system and universal identification informa- 
tion known even outside the print control system. 

50 

5. A print control system according to claim 3, wherein 
said job element list includes identification informa- 
tion on said page data and identification information 
on said job description file and wherein, when a ref- 
erenced job element list contains identification 55 
information on another job description file, said job 
control module references the job element list of the 
another job description file. 



6. A print control system according to claim 1 , wherein 
said job description file contains the print attributes 
of the entire job, said page data contains the print 
attributes of each page, and wherein said job con- 
trol module controls printing according to the print 
attributes in said job description file and the print 
attributes in said page data. 

7. A print control system according to claim 6, wherein 
said job description file contains attribute priority 
information determining which print attributes to 
use when the print attributes in said job description 
file and the print attributes in said page data do not 
match and wherein said job control module controls 
printing according to said attribute priority informa- 
tion. 

8. A print control system according to claim 1, 
wherein, upon receiving a re-print instruction with a 
job description file specified, said job control mod- 
ule reads the job description file from said job 
description file storage module and controls print- 
ing. 

9. A print control system according to claim 1, 
wherein, upon receiving a file revision instruction 
with a job description file and revisions specified, 
said job control module reads the job description 
file from said job description file storage module 
and revises the contents. ' ■* ■ 

10. A print control system according to claim t; further 
comprising an editing unit for use in editing the con- 
tents of said job description file. 

11. A print control system according to claim 1, further 
comprising a management table containing refer- 
ence relationship information on each of said job 
description file and said page. 

12. A print control system according to claim 1, further 
comprising a deletion module deleting a job ele- 
ment, wherein, when a job element is deleted from 
a print job, said deletion module checks if the dele- 

7 ■ tion has an effect on any other print job and deletes 
the job element only when there is no effect. 

13. A print control system according to claim 1 , further 
comprising an archive execution module archiving 
data, in whole or An part, from said job description 
file storage module or said page data storage mod- 
ule. 

14. A print control system according to claim 13, further 
comprising an archive information addition module 
adding archive information during said archiving. 

1 5. A print control system according to claim 1 4, further 
comprising a restore execution module restoring 



a job description file storage module containing 20 
job description files each containing a job ele- 
ment list for each print job; 
a page data storage module containing page 
data associated with a page image for each 
page; and 25 
a job control module extracting and sending to 
a printer a page image, required for printing, 
according to a job element list in said job 
description file, wherein said print job is man- 
aged on a job basis and page basis. 30 



18 



35 



EP 0 806 721 A1 



36 



data archived during said archiving back into the 
print control system. 

1 6. A print control system according to claim 1 5, further 
comprising a retrieval module searching data s 
restored during said 'restoration for a particular 
piece of data based on said archive information. 

17. A print control system according to claim 15; 
wherein said restore execution module restores 10 
only page data not found in the print control system 
during said restoration. 

18. A print control system according to claim 1, further 
comprising an image data creation module creating, is 
image data for each item of displayed page data 

1 9. A print control system according to claim 3, wherein 
said page data is created for each color. 

20 

20. A print control system according to daim 1, further 
comprising a job combination module creating a 
combination job by combining a plurality of print 
jobs, wherein said job combination module creates 
the job description file of said combination job 25 
according to the job description files of the print 
jobs before combination. 

21. A print i control; system according to claim 20, 
wherein, when a selective binding description for 30 
specifying the number of copies of each job ele- 
ment set is contained in one of the job description 
files of the print jobs before combination, said, job 
combination module creates the job description file 

of the combination job while maintaining all the con- 35 
ditions of the selective binding. 

22. A print control system according to claim 20, 
wherein, when a selective binding description for. 
specifying the number of copies of each job ele- 40 
mertt set is contained in one of the job description 
files of the print jobs before combination, said/job 
combination module creates the job description file 

of the combination job white maintaining a part of 
the conditions of the selective binding. .<• >. 45 

23. A print control system according to claim 20, 
wherein,, when a selective binding description .for 
specifying the number of copies of each job ele- 
ment set is contained in one of the job description so 
files of the print jobs before combination, said -job 
combination module creates the job description file 

of the combination job by clearing the selective 
binding description. ' 

24. A print control system according to claim 20, further 
comprising means for selective job combination 
conditions for said job combination module. 



25. A print control method, comprising the steps of: 

creating a job description file containing a job 

element list for each print job; 

creating page data, associated with page 

image, for each page; and - 

extracting and sending a page image to a 

printer according to the job element list in said , 

job description file. , 

26. A print control method according to claim 25, 
wherein a plurality, of print jobs share the same 
page data by allowing a plurality of job description 
files to reference the same page data. 

27. A recording medium containing a print control pro- 
gram, wherein said print control program comprises 
the functions of: 

creating a job description file containing a job 

element list for each print job; 

creating page data, associated with a page * 

image, for each page; and . 

extracting and sending a page image to a 

printer according to the job element list in said 

job description file.. .„ 
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Page ID 




(JOB INTERPRETATION, 
ID ASSIGNMENT) 



1 



T 

16-1 



16-2 



16-3 
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\ 



16-1 



JDFID: 10. . * ' \ \ - V 

UniquelD: 9503051 0000 01 2345ab60001 0 



JOB DESCRIPTION FILE 



PAGE DATA ON PAGE 1 



Page ID: 1 '7.,;; ■ 

1 6 _2 . UniquelD: 9503051 OOQ0 3i;2^45ab600001 



PAGE DATA ON PAGE 2. 



16-3 



Page ID: 2 •• ' • 

UniquelD: 95030510000 61 2345ab600002 



PAGE DATA ON PAGE 3 



. I 



Page ID: 3 

UniquelD: 9503051 000091 2345ab600003 



Fig. 2 
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JDF PD 
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\ 



\ 



[JDF ID 10] 
ContenlsSelect:[1|1,2,3I) 
ContentslDs: 1,2,11 



\ 

, \ 



[JDF ID 11] 

ContentsSelect: [1 [1,2,3]] 
ContentslDs: 3,4,5 



PRINT PAGE 



^7 (PRINT JDF ID 10) 



3 



(PRINT JDF ID 11) 



(PRINT JDF ID 10) 



Fig. 3 
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^ JDF EXAMPLE (1) 



%%JobDescriptionRle 
Title: Titlel 
ContentsSelect: [1(1,3], 1[2,3fl 
MediaSelect: A4 
MediaPrecedence: Job 
Color: Color 
Plex: Simplex 
Copy: 1 
ContentslDs: 2, 3, 6 
HoldTiming: None 
JobSave: TRUE 
RipFileSave: FALSE 



Fig. 5 



, JDF EXAMPLE (2) 



%%JobDescriptionFile 
Title: Title2 
ContentsSelect: [1{i,3], 1 [1 ,2,3]] 

MediaSelect: A3 
MediaPrecedence: Page 
Color: Color 

Plex: Duplex 

Copy: 2 

ContentslDs: 951 01 001 01 01 1 1 234567b00002, 
951 01 001 01 01 1 1 234567D00003, 
951 01 001 01 01 1 1 234567b00006, 

HoldTiming: BeforeRIP 

JobSave: TRUE 

RipFileSave: FALSE 



Fig. 6 
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JDF PRINT INSTRUCTION FILE (JPF) DESCRIPTION 

1 




-JPF EXAMPLE 

_j 

%%JDFPrint: 96031 42020201 2345ab600001 



Fig. 8 
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rJRF EXAMPLE (!)• 



%%JDFRevise: 96031 31 01 01 01 2345ab60001 
ReplaceSet: 1,$2 
ReplaceSet: 2,$1 
OriginalJDFDelete: FALSE 
%%JDFReviseEnd i 



Fig. 10 



JRF EXAMPLE (2) 



%%JDFRevise: 96031 31 01 0101 2345ab60001 
ContentsSelect: ; 1 ,[2, 1,3,4] 

OriginalJDFDelete: TRUE. 

ContentsID: 9503030303031 234567a00001 , 

" 9503030303031 234567a00002, 
$1,$2 

%%JDFReviseEnd 



Fig. 1 1 
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SYSTEM BASIC ROUTINES 



( START ) 

3^ 



< INSTRUCT TO PRINT^ >^— ^ PRINT ROUTINE (Fig. 16) 
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